<!DOCTYPE html>
<html>

<head>
  <meta charset="UTF-8" />
  <title>过滤器</title>
  <!-- 引入Vue -->
  <script type="text/javascript" src="../js/vue.js"></script>
  <!-- 引入Day.js -->
  <script type="text/javascript" src="../js/dayjs.min.js"></script>
</head>
<!-- 
    过滤器：
      定义：对要显示的数据进行特定格式化后再显示（适用于一些简单逻辑的处理）。
      语法：
          1.注册过滤器：Vue.filter(name,callback) 或 new Vue{filters:{}}
          2.使用过滤器：{{ xxx | 过滤器名}}  或  v-bind:属性 = "xxx | 过滤器名"
      备注：
          1.过滤器也可以接收额外参数、多个过滤器也可以串联
          2.并没有改变原本的数据, 是产生新的对应的数据
 -->

<body>
  <!-- 准备好一个容器-->
  <div id="root">
    <h2>显示格式化后的时间</h2>
    <!-- 计算属性实现 -->
    <h3>现在是：{{fmtTime}}</h3>
    <!-- methods实现 -->
    <h3>现在是：{{getFmtTime()}}</h3>
    <!-- 过滤器实现 -->
    <h3>现在是：{{time | timeFormatter}}</h3>
    <!-- 过滤器实现（传参） -->
    <h3>现在是：{{time | timeFormatter("YYYY-MM-DD") | mySlice}}</h3>
  </div>
</body>

<script type="text/javascript">
  Vue.config.productionTip = false; // 阻止Vue在启动时生成生产提示。
  // 全局过滤器
  Vue.filter('mySlice', function (value) {
    return value.slice(0, 4)
  })

  const vm = new Vue({
    el: "#root",
    data: {
      time: 1636338703124 // 时间戳
    },
    computed: {
      fmtTime() {
        return dayjs(this.time).format('YYYY年MM月DD日 HH:mm:ss')
      }
    },
    methods: {
      getFmtTime() {
        return dayjs(this.time).format('YYYY年MM月DD日 HH:mm:ss')
      }
    },
    // 局部过滤器
    filters: {
      timeFormatter(value, str = "YYYY年MM月DD日 HH:mm:ss") {
        return dayjs(value).format(str)
      }
    }
  });
</script>

</html>